背景介绍
最近转行做java后台了,对于java的并发完全不熟悉,于是到网上各种搜资料。
接到的一个任务是一个很简单从数据库里面读取一些表到内存里面,然后做一个缓存。
读数据库用的EJB3的Entity Bean; 服务是基于JBoss的MBean;访问接口是EJB3的stateless session bean;
因为session bean是多线程的方式访问Mbean的,所以要考虑内存数据的读写问题。
于是有个前辈就告诉我要用读写锁,也就是ReentrantReadWriteLock了,前辈还顺口提了一句说:“极端情况有可能写锁会一直被阻塞”
因为不是很清楚线程被阻塞时会发生什么,自己写了两个类来测当读锁被阻塞时会怎样。
一个测试类,使用读写锁保护一个int值。
package cfy.study.concurrency;
import java.util.Random;
import java.util.concurrent.locks.ReentrantReadWriteLock;
import java.util.concurrent.locks.ReentrantReadWriteLock.ReadLock;
import java.util.concurrent.locks.ReentrantReadWriteLock.WriteLock;
public class ReadWriteLockTest {
private static int data = 0;
private static ReentrantReadWriteLock rwLock = new ReentrantReadWriteLock();
private static ReadLock rLock = rwLock.readLock();
private static WriteLock wLock = rwLock.writeLock();
public static void read(){
String threadName = Thread.currentThread().getName();
System.out.println("\n"+threadName+" wait for ReadLock");
rLock.lock();
try{
System.out.println(threadName+"read data:"+data);
System.out.println("wait for awhile");
long time = System.